package com.ruoyi.system.mapper;

import com.ruoyi.system.domain.dto.BillUsageVo;
import com.ruoyi.system.domain.vo.AllBillListVo;
import com.ruoyi.system.domain.vo.BillInfoVo;
import com.ruoyi.system.domain.vo.BillListVo;
import com.ruoyi.system.domain.vo.UserInfoByBillInfoIdVo;
import org.apache.ibatis.annotations.Param;

import java.time.LocalDateTime;
import java.util.List;

/**
 * @author xy
 * @version 1.0
 * @description:
 * @date 2024/7/4 9:38
 */
public interface BillInfoMapper {
    public BillInfoVo selectBillInfo(@Param("bill_info_id") Long billInfoId);

    /**
     * 根据账单ID查询用户邮箱信息
     *
     * @param billInfoId
     * @return
     */
    public UserInfoByBillInfoIdVo selectUserEmailByBillInfoId(Long billInfoId);

    /**
     * 查询用户上个月是否支付账单
     *
     * @param userId
     * @return
     */
    public Long selectUserLastBillIsPaid(Long userId);

    /**
     * 查询用户上月账单金额
     * @param userId
     * @return
     */
    public BillListVo selectUserLastBillInfo(Long userId);

    /**
     * 插入一条账单
     *
     * @param userId
     * @return
     */
    public int insertBillInfo(@Param("userId") Long userId,
                              @Param("lastUsage") int lastUsage,
                              @Param("nowUsage") int nowUsage,
                              @Param("payAmounts") float payAmounts);

    /**
     * 查询账单列表
     *
     * @param userId
     * @return
     */
    public List<BillListVo> selectBillList(Long userId);

    /**
     * 查询所有用户的账单列表
     *
     * @return
     */
    public List<AllBillListVo> selectAllBillList();

    /**
     * 更新账单信息
     *
     * @param billInfoId
     * @param payDateTime
     * @param payAmounts
     * @return
     */
    public int updateBillInfo(@Param("billInfoId") Long billInfoId,
                              @Param("payDateTime") LocalDateTime payDateTime);

    /**
     * 查询账单用电量
     *
     * @param billInfoId
     * @return
     */
    public BillUsageVo selectBillUsage(@Param("billInfoId") Long billInfoId);

    /**
     * 根据用户ID查询上月账单用电量
     *
     * @param userId
     * @return
     */
    public BillUsageVo selectBillUsageByUserId(Long userId);

    /**
     * 查询用户上月账单是否已经添加
     * @param userId
     * @return
     */
    public int selectUserIsInsert(Long userId);
}
